<template>
  <div>
    <el-form ref="form" :model="form" :rules="rules" label-width="120px">
      <el-form-item label="部门名称" prop="name">
        <el-input
          v-model="form.name"
          style="width: 80%"
          placeholder="4-50个字符"
        />
      </el-form-item>
      <el-form-item label="部门编码" prop="code">
        <el-input
          v-model="form.code"
          style="width: 80%"
          placeholder="1-50个字符"
        />
      </el-form-item>
      <el-form-item label="部门负责人" prop="manager">
        <el-select
          v-model="form.manager"
          style="width: 80%"
          placeholder="请选择"
        >
          <el-option
            v-for="item in employees"
            :key="item.id"
            :value="item.username"
            :label="item.username"
          />
        </el-select>
      </el-form-item>
      <el-form-item label="部门介绍" prop="introduce">
        <el-input
          v-model="form.introduce"
          style="width: 80%"
          placeholder="1-300个字符"
          type="textarea"
          :rows="3"
        />
      </el-form-item>
      <el-form-item>
        <el-button
          type="primary"
          size="small"
          @click="onSubmit"
        >确定</el-button>
        <el-button size="small" @click="onCancel">取消</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
import { getEmployeeSimple } from '@/api/employees'
import {
  addDepartments,
  getDepartDetail,
  updateDepartments
} from '@/api/departments.js'
export default {
  props: {
    id: {
      type: String,
      required: true
    },
    isEdit: {
      type: Boolean,
      required: true
    },
    originList: {
      type: Array,
      required: true
    }
  },
  data() {
    const validCode = (rule, value, callback) => {
      console.log('validCode....', value)
      // value就是当前用户输入的编码,它不能与现有的编码数据(originList)重复
      // 如果重复,就验证不通过
      // if(value能与现有的编码数据(originList)重复) {}
      // 1. 从originList([{id,pid,name,code},{id,pid,name,code}])中找出全部的编码数据
      let existCodeList = this.originList.map(item => item.code)
      if (this.isEdit) {
        // 把当前正在编辑的部门编号(this.id)排除在外
        console.log('现在是编辑状态,正在编辑的id是', this.id)
        // 过滤掉当前的部门,map得到部门编号列表
        existCodeList = this.originList.filter(item => item.id !== this.id).map(item => item.code)
      }
      console.log('existCodeList', existCodeList)
      // 2. 检查value 是否存在其中
      // if (existCodeList.includes(value)) {
      //   callback(new Error('编码' + value + '已经存在'))
      // } else {
      //   callback()
      // }
      existCodeList.includes(value) ? callback(new Error('编码' + value + '已经存在')) : callback()
    }
    const validName = (rule, value, callback) => {
      // 思路: 被占用的名字是这个部门的子部门
      let existNameList = this.originList.filter(item => item.pid === this.id).map(item => item.name)
      console.log('validName.... , 当前被校验的名字是', value)
      // 如果是编辑,则被占用的名字 = 兄弟 - 自己
      if (this.isEdit) {
        // 1. 找到当前被编辑的元素
        const dept = this.originList.find(item => item.id === this.id)
        // 2. 取出pid(它的父级是谁)
        const pid = dept.pid
        // 3. 过滤: 同一个父级,不包括自己, map: 只要需要名字
        existNameList = this.originList.filter(item => item.pid === pid && item.id !== this.id).map(item => item.name)
      }
      console.log('被占用的名字列表', existNameList)
      if (existNameList.includes(value)) {
        callback(new Error('名字' + value + '已经被占用了'))
      } else {
        callback()
      }
    }
    return {
      employees: [],
      form: {
        name: '', // 部门名称
        code: '', // 部门编码
        manager: '', // 部门管理者
        introduce: '' // 部门介绍
      },
      rules: {
        name: [
          { required: true, message: '部门名称不能为空', trigger: 'blur' },
          { min: 4, max: 50, message: '部门名称要求4-50个字符', trigger: 'blur' },
          { validator: validName, trigger: 'blur' }
        ],
        code: [
          { required: true, message: '部门编码不能为空', trigger: 'blur' },
          { min: 1, max: 50, message: '部门编码要求1-50个字符', trigger: 'blur' },
          { validator: validCode, trigger: 'blur' }
        ],
        manager: [
          { required: true, message: '部门负责人不能为空', trigger: 'blur' }
        ],
        introduce: [
          { required: true, message: '部门介绍不能为空', trigger: 'blur' },
          {
            min: 1,
            max: 300,
            message: '部门介绍要求1-300个字符',
            trigger: 'blur'
          }
        ]
      }
    }
  },
  created() {
    this.loadEmployee()
    this.loadDetail()
  },
  methods: {
    async loadEmployee() {
      const rs = await getEmployeeSimple()
      console.log('员工信息', rs)
      this.employees = rs.data
    },
    // 获取当前部门的详情
    async loadDetail() {
      if (this.isEdit) {
        // alert('现在是编辑，要去获取详情')
        const res = await getDepartDetail(this.id)
        console.log('现在是编辑，要去获取详情', res)
        this.form = res.data
      }
    },
    // 执行具体的添加动作
    async doAdd() {
      // 去获取pid: 当前要添加的部门所在的父级的id
      // 从props中获取
      // 1. 组装参数
      const params = { ...this.form, pid: this.id }
      console.log(params)
      // 2. 调用接口
      const rs = await addDepartments(params)
      console.log(rs)
      // 3. 通知父组件：关闭弹层，再次更新数据
      this.$emit('update-depart')
    },
    async doEdit() {
      try {
        await updateDepartments(this.form)
        this.$message({ type: 'success', message: '修改成功' })
        this.$emit('update-depart')
      } catch (err) {
        console.log(err)
        this.$message({ type: 'error', message: err })
      }
    },
    hSubmit() {
      // 先省略表单验证
      // 根据 isEdit的值，决定做保存还是添加
      // if (this.isEdit) {
      //   this.doEdit()
      // } else {
      //   this.doAdd()
      // }
      this.isEdit ? this.doEdit() : this.doAdd()
    },
    onSubmit() {
      // 先省略表单验证
      // 根据 isEdit的值，决定做保存还是添加
      // if (this.isEdit) {
      //   this.doEdit()
      // } else {
      //   this.doAdd()
      // }
      // 表单验证
      this.$refs.form.validate((valid) => {
        if (valid) {
          this.isEdit ? this.doEdit() : this.doAdd()
        }
      })
    },
    // 用户点击了取消
    onCancel() {
      // resetFields是element-ui中的el-form组件提供一个api,它的作用是:
      // 1. 重置表单数据
      // 2. 清空校验结果(页面上红色的提示)
      this.$refs.form.resetFields()
      // 通知父组件去关闭弹层
      this.$emit('close')
    },
    resetForm() {
      this.$refs.form.resetFields()
      console.log('resetForm')
    }
  }
}
</script>

<style>
</style>
